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Amendments To the Claims 
Kindly i^place the claims as follows. 



1 

2 



I. (previously presented) A computer, comprising: 

a processor pipeline designed to alternately execute instrucUons coded for firet and 

3 second different computer architectures or coded to implement first and second different 

4 processing conventions; 

5 a memory for storing instructions for execution by the processor pipeline, the 

6 memory being divided into pages for management by a virtual memory manager, a single 

7 address space of the memory having first and second pages; 

8 a memory unit designed to fetch instmctions from the memory for execution by the 

9 pipeline, and to fetch stored indicator elements associated with respective memory pages of 

10 the single address space from which the instructions are to be fetched, each indicator element 

1 1 designed to store an indication of which of two different computer architectures and/or 

12 execution conventions under which instruction data of the associated page are to be executed 

13 by the processor pipeline, the first architecture having a pre^lefined, estabUshed definition. 

14 the computer providing a faithful implementation of the first architecture: 
the memory unit and/or processor pipeline further designed to recognize an execution 

flow ftom the first page, whose associated indicator element indicates the first architecture or 

17 execution convention, to the second page, whose associated indicator element indicates the 

1 8 first architecture or execution convention, and in response to the recognizing, to adapt a 

19 processing mode of the processor pipeline or a storage content of the memory to effect 

20 execution of insmictions in the architecture and/or under Uie convention indicated by the 

21 indicator element corresponding to the instruction's page. 

2. (original) The computer of claim 1: 

wherein the two architectures are two instruction set architectures; 



15 
16 
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and wherein u,e ad^ng i„o,„de, c„„„,B„g i„,^aor. ..ccn^on hartw^ 
computer to i„«n».. .he in^^^ according .o U,e ,wo i„stt„c.™ s« a,chi,««.res 
according to Ihe indicator elements. 



3. (original) T>««>mp„.erof claim ,,„„ereinthe,woco„ven,i<.„.a„te,^, 
second calling conventions, and ftmtier comprising: 

hardware and/or soihvare designed to ^oogni^ „he„ ^ 
or transfened from a region whose intLcator eiemen, indicates the eailing convention to 
a n^^on whose i„dic«or eletnen, indicates ti» second caiUng convention, and in tesponse to 

the .cognition, .„ alter d.e datastorage content Of tt,ecomp„ter,„createap,x,g,amco„,e« 
under ti.e second caUing convention titat is logically e,,„i,„en. ,o a pte-altetation program 

context under Uie first calUng convention. 



1 4. (previonsly presented) A tneUiod. comprising 0,e steps of: 

2 ex«:„Ung instn«,i«,s fetched from first and second tegions of a memory of a 

3 computer, Ute insu^ctions of the fi.t and second regions being coded for execution 6, 

4 computers of Brs. and second architectutes or following a„a second data storage 

5 conventions, „spectively. tite memory regions having associated fi« and second mdieator 

6 ^'~-«>-^-.oreleme„,seachhavingaval„eindicating,hearchitec„ne„rd«, 
stin^c convention under which insti^ons from the associated region are to be exerted. 

ti»r™a.h,tec««havingap,e-defined,estabhsheddennitio„.thecomputerprovidi„ga 
taithfiil implementation of the firet architecture; 

When execution of the i„3tn.ctio. data flow, or transfer ft., the first .gion to the 
second, adapting the computer for execution in the second architecture or convention. 

5. (original) The method of claim 4. wherein: 
the regions are pages managed by a virtual memory manager. 
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6. (Original) The method of claim 5. wherein the indicator elements are stored in a 
tabJe of indicator elements distinct from a primary address tmnslation table used by the 
virtual memory manager, the indicator elements of the table associated with con^ponding 
pages of the memory. 



7. (original) The method of claim 5. wherein the indicator elements are stored in a 
table, each indicator element associated with a corresponding physical page frame. 

8. (original) The method of claim 5. wherein the entries are entries of a translation 
look-aside buffer. 



9. (original) The method of claim 4, wherein the regions are lines of an instruction 

cache. 



10. (original) The method of claim 4: 

wherein the two architectures are two instmcUon set architectures; 

and wherein the adapting step includes controlling instmction execution hardware of 
the computer to interpret the inslnictions according to the two instruction set architectures 
according to the indicator elements. 

11. (original) The method of claim 10, wherein: 

the regions are pages managed by a virtual memory manager. 

12. (previously presented) The method of claim 11. wherein the indicator elements 
are stored in a table whose entiies are indexed by physical page frame number. 

13. (original) The method of claim H. wherein the entry is one entry of a translation 

look-aside buffer. 
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14. (original) The method of claim 10, wherein a mode of execution of the 
instmctions is changed without software mtervention when execution flows or transfers fh>m 
the first region to the second. 

15. (original) The method ofclaim 10. wherein execution ofthe computer takes an 
excepdon when execution flows ortransfe,^ from the firet region to the second. 

16. (original) The method of claim 15. wherein the mode of execution of the 
instructions is expUcitly controlled by an exception handler. 

17. (original) The method of claim 10, wherein: 

one of the regions stores an off-the-shelf operating system binary coded in an 
instmction set non-native to the computer, the non-native instruction set providing access to a 
reduced subset of the resources of the computer. 

18. (original) The method of claim 10. wherein the two conventions are first and 
second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred fix,m a region whose 
indicator element indicates the n,.t data storage convention to a region whose indicator 
element indicates the second data storage convention, and in response to the recognition, 
altering the data storage content of the computer to create a progmm context under the 
second data storage convention that is logically equivalent to a pre-alte,^ion progmm 
context under the first data storage convention. 

19. (original) The method of claim 18. wherein: 

the regions are pages managed by a virtual memory manager; 
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one Of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stacJc-based calling convention. 

20. (Original) The method of clai™ 18, further comprising the steps of 

classifying control-flow instmctions of a computer instruction set into a plurality of 

Classes; and 

during execudon of e„™pu,er, as part of .he »ec„Uo„ „f 

ofth.,.sm,«i™3e,.„pda.„ga«cord„fu«cIass„fu„c,..s,f,edc„„„ol-fl„„i„...„ea„„ 

most recently executed; 

U.e Mj^„^ w.g del^^taed. at lea.. i„ pan, by u,. i„sBu«io„ class «cori. 

21. (previously presented) The method of data 18.whe.ei„: 
theinstn^tion data coded forexecutt™, by a fim of d„, „o insttucdon set 
>rc>.^ Observes a da,a s^rage co„ve.U„„ associated with the tat architect,, and 

.nstractiondatac^led for execution byasecond Of the tw„,„.t™cao„ set atchite«utl. 
ob^es a .econd, di«e,e„., data stooge convention associated with Ute s^ond atohitectu. 
a stngle .ndicator element indicating both the insttucdon set atchitecture and the data storage' 

convention; '^*a6& 

and tethercontprising the step of „=cognizing when pn,gram exccudon fl„„s or 
Wen fiou. a tegion using the fltst in..rt,cHon set archi^ctute to a region using d,e second 

.nsuucut^setarehitecn^, and in respor«.o.herec„g„ido„,ad,„.i„g .he data storage 
content of the computer from the fim stomge convendon to the second. 

22. (pn^viously presented) A method; comprising the steps of- 
execuUnginstnicdons fetched from first and second regions of a memory of a 
computer, the insuucUons of the firs. »,d second regi ons betng coded for execution by 
compute, following and second data borage conventions, the memory regions having 
assocated nrst and second indtcator elements, the indicator elements each having a value 
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6 indicating the data storage convention under which instructions from the associated region 

7 are lo be executed; 

8 recognizing when program execution has flowed or transferred from a region whose 

9 indicator element indicates the first data storage convention to a region whose indictor 

10 element indicates the second data storage convention, and in response to the recognition, 

1 1 altering the data storage content of the computer to create a program context under the 

12 second data storage convention that is logically equivalent to a pre-alteration program 

13 context under the first data storage convention. 

23. (previously presented) The method of claim 22, further comprising the step of: 
overlaying the logical resources of the first and second instruction set architectures 

onto the physical resources of the computer according to a mapping that assigns 
corresponding resources of the two architectures to a common physical resource of a 
computer when the resources serve analogous functions in the calling conventions of the two 
architectures. 

24. (previously presented) The method of claim 22. wherein the adjusting step 
further comprises: 

altering a bit representation of a datum from a first representation in the first 
convention to a second representation in the second convention, the alteration of 
representation being chosen to preserve the meaning of the datum across the change in data 
storage convention. 

25. (original) The method of claim 22, wherein the adjusting step furdier comprises: 
copying a datum fi-om a first location to a second location, the first location having a 

use under the first data storage convention analogous to the use of the second location under 
the second data storage convention. 
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26. (original) The method of claim 22, wherein the adjusting step further comprises: 
copying a datum from a third location to a fourth, the third location having a use 

under the first data storage convention analogous to the use of the third location under the 
first data storage convention and to the fourth location under the second data storage 
convention, a program for the copying being programmed to assume that exactly one of the 
first and third locutions is no longer required by the execution of the program. 

27. (previously presented) The method of claim 22. wherein 

a rule for copying data from the first location to die second is determined by 
examining a descriptor associated with the instruction before the recognized execution flow 
or transfer. 



28. (original) The method of claim 22. wherein the two conventions arc two calling 
conventions. 



29. (original) The method of claim 28, wherein: 

one of the two caUing conventions is a register-based calling convention, and the 
other calUng convention is a memoTy stack-based caUing convention. 

30. (original) The method of claim 28, wherein: 

the regions are pages managed by a virtual memory manager. 

31. (previously presented) The method of claim 30, wherein the indicator elements 
are stored in a table whose entries are indexed by physical page frame number. 

32. (original) The method of claim 31 , wherein the entry is one entry of a translation 
look-aside buffer. 
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33. (previously presented) The method of claim 28, further comprising the step of: 
taking a processor exception in response to the recognition, a handler for the 

exception programmed to copy a datum from a first location to a second location, the firet 
location having a use under the first data storage convention analogous to the use of the 
second location under the second data storage convention. 

34. (previously presented) The method of claim 22, further comprising the step of: 
classifying control-flow insliuctions of a computer instruction set into a plurality of 

classes; and 

during execution of a program on a computer, as part of the execution of instnictions 
of the instruction set, updating a record of the class of the classified control-flow instruction 
most recently executed; 

the adjusting process being determined, at least in part, by the instraction class record. 

35. (original) The method of claim 34, wherein: 

one of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stack-based calling convention. 

36. (original) The method of claim 34, wherein: 

in some of the control-flow instructions, the classification is statically deteimined by 
the opcode of the instructions; and 

in other of the control-flow instiaictions. die classification is dynamically determined 
based on a full/empty status of a register. 

37. (previously presented) A computer processor, comprising: 
a processor pipeline configured to alternately execute instructions of computers of 



3 two different architectures or processing conventions; and 
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a memory unit designed to fetch instructions from a computer memory for execution 
by the pipeline, and to fetch stored indicator elements associated with respective memory 
regions of a single address space froo, which the instmctions ^ to be fetched, each indicator 

7 element designed to store an indication of the architecture or execution convention under 

8 whrch the instruction data of the associated ..gion are to be executed by the processor 
pipeline, the first architecture having a preskftned. established definition, the computer 
providing a faithful implementation of the first architecture; 

the memon. unit and/or processor pipeline further designed to recognize an execution 
flow or transfer from a region whose indicator element indicates one aK:hitectme or 
13 execution convention to another. 

38. (onginal) The computer processor of claim 37. wherein the indicator elements 
are stored m a table of indicator element, distinct fron. a tt^slation table 
used by the virtual memory manager, the indicator elements of the table associated w, th 
corresponding pages of the memory. 

39. (previously presented) The computer processor of claim 37. further comprising: 
a translation look-aside buffer (TLB); and 

TLB control circuitry designed to load the indicator elements into the TLB from a 
table stored in memory, the entries of the table being indexed by associated with 
corresponding physical page Jrame number. 

40.(original) The computer processor of claim 37. wherein the two architectures are 
two mstrucUon set architectures, and further comprising: 

processor pipeline control circuitry designed to control the processor pipeline to 
effect interpretation of the instructions under the two instruction set architectures ^temately 

according to the associated indicator dements. 
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41. (original) The computer processor of claim 40, further comprising: 

r software programmed to manage a transition between the execution of a program 
executing in the first instruction set architecture, being an instruction set architecture native 
to the computer processor, and execution of an off-the-shelf operating system coded in the 
second instruction set, being an instruction set non-native to the computer, providing access 
to a reduced subset of the resources of the computer. 

42. (original) The computer processor of claim 40: 

each indicator element being further designed to store an indication of a calling 
convenUon under which instruction data of die associated region are coded for execution 
by the processor pipeline; 

and further comprising software programmed to alter the data storage content of a 
computer using the computer processor to create a program context under the second calling 
convention that is logically equivalent to a pre-alteration program context under the first 
calling convention; 

the memory unit ftirther designed to recognize when program execution has flowed or 
transferred from a region whose indicator element indicates the first calling convention to a 
region whose indicator element indicates the second calling convention, and in response to 
the recognition, to invoke the transition management software. 

43 . (original) The computer processor of claim 42, wherein the memory unit is 
designed to recognize a single indicator element to indicate both die instruction set 
architecture and calling convention of a region. 

44. (original) The computer processor of claim 42, wherein the memory unit and 
software are designed to effect a transition between instruction boundaries, between 
execution in a region coded in the first instruction set using the first calling convenUon to 
execution in a region coded in the second instruction set using the second calling convention, 
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so that code at the source of the flow or transfer may effect the execution tiMSition WithOUt 
being specially coded for code at the destination. 



45. (original) The computer processor of claim 42, wherein: 

one of the two callir,g conventions is a register-based calling convention, and the 
other calUng convention is a memory stack-based calling convention. 

46. (original) The computer processor of claim 42, wherein the logical resources for 
support of the first and second instruction set architectures are overlaid on the physical 
resources of the computer processor according to a mapping that assigns conesponding 
resources of the two architectures to a common physical resouit^e when the tesources serve 
analogous functions in the calling conventions of the two architectures. 

47. (previously presented) The computer processor of claim 42, wherein 

a rule for altering the data storage content from the first calling convention to the 
second is determined by examining a descriptor associated with the location of execution 
before the recognized execution flow or transfer. 

4«. (original) The computer processor of claim 42, wherein control-flow instructions 
of the instruction set are classified into a plurality of classes; and 

the processor pipehne updates a record of the class of the classified control-flow 
instruction most recently executed: 

the storage alteration process being determined, at least m part, by the instruction 

class record. 

49. (original) The computer processor of claim 40, further comprising: 
a transition manager designed to effect a transition between the execuUon of code 
coded in instmctions of a first instruction set architecture and code coded in mstructions of a 
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second instruction set architecture, the transition manager designed to alter a bit 
..presentation of a ..urn fto. a first representation under the fi.t architecture to a second 
representation underthesecondarchitectu«.the.terationor.p^^^^^^^^^ 
P:.se.e ^e .eanin. o. the datu. ac^ss the Change in execuuon a^Hitecture. 

50. (original) ^-omputer processor of claim 40, ft«her comprising ci.ui^ 
2je..^^^ 

transferred from a region whose indicator element indicates one architectu. 
convention to another. 



or 

or execution 



51. (previously presented) A method, comprising: 

nsinpagesofaco^putermetnotymanagedbyavinualmemory 
n.a„ager.themst.ct.ondataofthepagesheingcodedfore.ecutio„,,.,^,,^^^^^^ 
compu.rsoft.o.fferentarehitect^.,..,„,_^^ 

.n asso.at.on with pages of d^ememor., storing cor^sponding inc^cator elements ' 

executed^thepages «^-or elements ^,„g stored in a table whose entries a. indexed by 
8 physical page frame number; maexed by 

execuOng i„..„.,i^ u,c page. <„ a co^„ ^ 
,o U,e page ta*a,..e_., , .^^^^^^ ^„ ^ 

52.(p„vi„„.„p^„^, ™'°»*°<'°'^'-n.51,whe«i„rt.pag«.i„di.a.cr 
elem«,« cached in a .ranslation Jook-asMe buffer. 



53. (p„v,ously present •n.'-'hcdofc,ata5.,w.e„i„tt„.„„,„^^^ 



are 
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controlling the instruction execution hardwa^ of the computer to interpret the 
instmotton. according to the two instruction set architectures acconUng to the indicator 
element. 



54. (^^ou.,y presented) Tie ™u,„d of e,.i„ 5,. »he„,„ ^ ™„ eo„ve„«cms are 
firs. a™i «e»„d daa s.o„ge convent, and fatter oompd^ng u,e «ap of: 

^cognizing When program execodon has flowed or Werred fem a region whose 
.nd»a.orcIeme„t indicates te to, d«a storage convendon .0 a re^on whose indicator 
demon, indicates the second dau s.on>ge co„ven.„„, .„d in response n, the ,ec„g„i«„„ 
Itenng the data storage conten. „, ,he computer u, create a program context umier the ' 
sec™,d dat. storage convention U,at is logically eqdvalen, ,0 a pre-altenuion program 
context under the first dau storage convention. 

55. (ptevioudy presented) „^ „roMn, 54, fur«,er comprising the steps of 
stonng instn«^on data in a third page, ,i,e i„stn«Uon data of the third page being 

coded forexecution by one o,thetw„.,chi.ec««s,a™,„hservi„gadatas,orageconve«io„ 
associated Witt, the other of the two aix*ilectuies; 

storing indicator elements indicating the data stot^ge convention observed by the 
mstnictions of Uie respective pages; and 

-ogm^ing each uansition of program execution ftom a page using the first data 

storage convention toapageasingttie second datastomgec^tvention. and in response totiie 
n^ognition. adjusting ,he data stomge content of the computer fn,n, d« first stoiage 
convention to the second, and vice-versa. 

56. (previously presented) The method of claim 53, wherein: 
the instruction data coded for execution by a first of the two instruction set 
archuectu^ observes a data storage convention associated with the fi.t architectun. and 
.nstn.ct,on data coded for execution by a second of the two inst^con set architectures 
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convenuon of the associated page; ^ 

co„«n. Of B.0 c„n,„«, f^ ^rs, *rag= conv=„U» ,„ u,e second. 

con>pnstag ^ s«p Of: ^ """"^ """'""o"' 

..S-s^-ba^ oal«„, co„v™«o„ ,„ , p,,e Jl^L^ 
calbng convention to the second. 



in 



ccp^„«aa..u„,f„„a«.^,ocaUo„.oafoun.,tf„.bta,,oc.«o„,avi„gaul 

fi«.da,a»„,ec«,ve„„o„a„<,„^.,^,^,„„„„^^^ 

™„. a p^^a™ f„, cop^„, ,^ J 

<-.andU^,ooa.o..„„.o„^^^,,,,„_,^„,^ 

of .he da.u™ oop,ed ^ ,^„„, of ^^,a,„„ ™ 

P^.*e„ea™„,„f«.e<^™ac™...»eba„.ei„da..«^eoo„ve„J ° 
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59. (previously p^cmed) The method of claim 54. wherein 
a rule for copying data from the fmt location to the .econd is determined h 
exam^ning a de..p.or associated with the instrue.on before the reco^ Z 
or transfer. "=«'8M2"i MecuOon flow 



60. (ohg,„al) The „Ka,o<l Of cto 54, fi,rt«r compn«„g 

during execution of a program on a computer as n«rt nf .h 
most recently executed; ''•ssuiea control-flow mstruction 

61. (cancelled) 



62. (cancelled) 



1 
2 
3 
4 
5 



(o^Uy.„^, ^^n-P^cessorcWp. comprise.. 

or convention to a page of the second, as indicted hv th. 
n indicator elements, and (c) to alter an -«P«ctive associated 

cl (c) to alter a processmg mode of the instruction umt or a storage 
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12 content of the memory to effect execution of instructions in accord with the indicator element 

13 associated with the page of the second architecture or convention; 

14 wherein the indicator elements arc stored in a tabic distinct from a primary address 

15 translation table and from portions of the primary address translation table cached in a TLB 

16 (translation lookaside buffer) used by a virtual memory manager, the indicator elements of 

17 the table being stored in association with respective pages of the memory. 

64. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in association with respective physical page frames. 

65. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in association with respective virtual pages. 

66. (previously presented) The microprocessor chip of claim 63» wherein the 
indicator elements are stored in entries of a translation look-aside buffer 

67. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stoned in an instruction cache, 

68. (previously presented) The microprocessor chip of claim 63, wherein a mode of 
execution of the instructions is changed without software intervention when execution flows 
or transfers from the first region to the second. 

69. (previously presented) The microprocessor chip of claim 63, the microprocessor 
chip being designed to raise an exception when execution flows or transfers irom the first 
region to the second; 

and further comprising exception handler software programmed to handle the 
exception by explicitly controlling a mode of execution of the instructions. 
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70. (previously presented) The microprocessor chip of claim 63, wherein the 
architecture or convention indicator elements are stored in a table whose entries arc indexed 
by physical page frame number, and cached in a translation look-aside buffer. 

71. (previously presented) The microprocessor chip of claim 63, wherein the two 
architectures arc two instruction set architectures, and the microprocessor chip controls the 
instruction unit to interpret the instructions according to the two instruction set architectures 
according to the indicator element corresponding to the pages from which the instructions are 
fetched. 

72. (original) The microprocessor chip of claim 71, further comprising: 
software programmed to manage a transition between the execution of a program 

executing in the first instruction set architecture, being an instruction set architecture native 
to the computer processor, and execution of an off-the-shelf operating system coded in the 
second instrucUon set, being an instruction set non-native to the computer providing access to 
a reduced subset of the resources of the computer. 

73 (previously presented) The microprocessor chip of claim 71 : 

each indicator element being further designed to store an indication of a data storage 
convention under which the instruction data of the associated page arc coded for execution 
by the instruction unit; 

and further comprising software progranuned to alter the data storage content of a 
computer using the microprocessor chip, to create a program context under the second data 
storage convention that is logically equivalent to a prc-alteration program context under the 
first data storage convention; 

the microprocessor chip further designed to recognize when program execution has 
flowed or transferred from a region whose indicator element indicates the first data storage 
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convention to a region whose indicator element indicates the second data storage convention, 
and in response to the recognition, to invoke the tramsition management software. 

74. (original) The microprocessor chip of claim 73, being further designed to: 
to retrieve instruction data from a third page, the instruction data of the third page 
being coded for execution by a first of the two architectures, and observing a data storage 

convention of the second of the two architectures; 

to retrieve indicator elements indicating the data storage convention observed by the 
instructions of the respective pages; and 

to recognize each transition oif program execution from a page using the first data 
storage convention to a page using the second data storage convention, and in response to the 
recognition, to adjust the data storage content of the computer from the first data storage 
convention to the second data storage convention, and vice-versa. 

75. (original) The microprocessor chip of claim 73, further designed to recognize a 
single indicator element to indicate both the instruction set architecture and calling 
convention of a page. 

76. (previously presented) The microprocessor chip of claim 71, further comprising 
hardware and/or software designed: 

(a) to retrieve calling convention indicator elements stored in association with 
respective pages of the memory, each calling convention indicator element indicating which 
of a register-based calling convention or a memory stack-based calling convention is 
observed by instructions of the page; 

(b) to recognize when instruction execution has flowed or transferred from a page of a 
memory-based convention to a page of the register-based calling convention, as indicated by 
the calling convention indicator elements associated with the respective pages, and 
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(C) in response to the recognition, to alter a storage content of the computer to create a 
program context under the register-based convention logically equivalent to a pre-alteration 
program context under the memory-based convention. 

77. (previously presented) The microprocessor chip of claim 63: 

wherein the two conventions are first and second data storage conventions; 

and further comprising software programmed to alter the data storage content of a 
computer using the microprocessor chip, to create a program context under the second data 
storage convention that is logically equivalent to a pre-alteration program context under the 
first data storage convention; 

the microprocessor chip being further designed to recognize when program execution 
has flowed or transferred from a region whose indicator element indicates the first data 
storage convention to a region whose indicator element indicates the second data storage 
convention, and in response to the recognition, to invoke the transition management 
software. 

78. (original) The microprocessor chip of claim 77, wherein the microprocessor chip 
and software are designed to effect a transition between instruction boundaries, between 
execution on a page coded in the first instruction set using the first calling convention to 
execution on a page coded in the second instruction set using the second calling convention, 
the software programmed to effect the execution transition without the code at the source of 
the transition bemg specially coded to interface with code at the destination of the transition. 

79. (original) The microprocessor chip of claim 77, wherein the two conventions are 
two calUng conventions. 
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80. (original) The microprocessor chip of claim 79, wherein: 

one of the two calling conventions is a register-based calling convention, and the 
other calling convention is a memory stack-based calling convention. 

81. (original) The microprocessor chip of claim 79, wherein the physical resources of 
the microprocessor chip arc associated to the logical resources of the first and second calling 
conventions according to a mapping that assigns corresponding logical resources to a 
common physical resource when the resources serve analogous functions in the two calling 
conventions. 

82. (original) The microprocessor chip of claim 79, further comprising: 
software and/or hardware designed to effect a transition between the execution of 

code coded under the first calling convention and code coded under the second calling 
convention, by altering a bit representation of a datum from a first representation under the 
first calling convention to a second representation under the second calling convention, the 
alteration of representation being chosen to preserve the meaning of the datum across the 
change in calling convention. 

83. (original) The microprocessor chip of claim 79, further comprising: 
software and/or hardware designed to copy a datum from a first location to a second 

location, the first location having a use under the first calling convention analogous to the use 
of the second location under the second calling convention. 

84. (previously presented) The microprocessor chip of claijn 79, further comprising: 
software and/or hardware designed to copy a damm from a third location to a fourth, 

the third location having a use under the first data storage convention analogous to the use of 
the third location under the first data storage convention and to the fourth location under the 
second data storage convention, the software and/or hardware for the copying being 
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programmed to assim^ that exactly one of the first and third locations is no longer i^uired 
by the execution of the program. 

85. (previously presented) Themicroprocessorchipof claim 63, further comprising 
hardware and/or software designed: 

(a) to retrieve calling convention indicator elements stored in association with 
respective pages of the memory, each calling convention indicator element indicating which 
of a register-based calling convention or a memory stack-based calling convention is 
observed by instructions of the page; 

(b) to recognize when instruction execution has flowed or transferred from a page 
using the register-based calling convention to a page using the memory stack-based 
convention, as indicated by the calling convention indicator elements associated with the 
respective pages, and 

(c) in response to the recognition, to alter a storage content of the computer to create a 
program context under the memory-based convention logically equivalent to a pie-alteration 
program context under the register-based convention. 

86. (previously presented) The microprocessor chip of claim 63, wherein control- 
flow instructions of the microprocessor's instruction set are classified into a plurality of 
classes; and 

the fetch and execute unit updates a record of the class of the classified control-flow 
instruction most recently executed; 

the storage alteration process being determined, at least in part, by the instruction 
class record. 
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87. (currently amended) A method, comprising the steps of; 
executing a control-transfer instnicUon under a fiist execution mode eeiitejrt of a 

computer, the instruction being architecturaJly defined to transfer control directly to a 
4 destination instruction for execution in a second execution inode eente** of die computer; 

before executing the destination instiuction. altering the data storage content of the 
computer to estabUsh a program context under the second execution mode eentejrt that is 
7 logically equivalent to the context of the computer as interpreted under the fim execution 

mode eeutwrt, the reconfiguring including at least one data movement operation not included 
9 in the architectural definition of die control-transfer instruction. 

88. (original) The method of claim 87, wherein the data movement includes at least 

one of : 

copying data from a general register to a memory stack; and 
copying data fix)m a memory stack to a general register. 

89. (currently amended) The method of claim 87, wherein: 

the transition for the first execution mode eentejrt to die second rnode eeatett is 
recognized in a difference between two indicator elements associated with the memory pages 
containing the control-transfer instruction and the destination instruction, respectively, the 
pages being under the management of a virtual memory manager. 

90. (previously presented) The mediod of claim 89, wherein die indicator elements 
are stored in a table whose entries arc indexed by physical page frame number. 

91. (original) The method of claim 89. wherein the indicator elements are stored in 
entiles of a translation look-aside buffer. 
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92. (currenUy amended) The method of claim 87. further comprising the step of. 
altering a bit representation of a datum from a fii^t repi^sentation in the first mode 

«o«te*t to a second representation in the second mode eefite«. the alteration of 
representation being chosen to preserve the meaning of the datum across the change in 
execution mode eeftteJrt. 

93. (previously presented) The method of claim 87, wherein 

a rule for copying data from the source memory or register to the destination register 
or memory is determined by examining a descriptor associated with the address of the 
control-transfer instruction. 



94. (previously presented) A method, comprising the steps of: 
executing a secUon of computer object code twice, without modification of the code 
section between the two executions, the code section materializing a destination address i 
a register and being architecturally defined to directly transfer control indirectf y through the 
register to the destination address, the two executions materializing two different destinaUon 
6 addresses; 



into 



the two destination code sections at the two materialized destination addresses being 
coded in two distinct insti^iction sets and, respectively, obeying the default calling 
conventions native to each of the two instruction sets, neither instruction set being a subset of 
10 the others. 



95. (original) The method of claim 94, wherein: 

the code at the first destination receives floating-point arguments and returns floating- 
point renmi values using a register-based calling convention; and 

the code at the second destination receives floating-point arguments using a memory- 
based stack calling convention, and returrts floating-point values using a register indicated by 
a top-of-stack pointer. 
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10 
11 



96. (previously presented) A microprocessor chip, comprising: 
two instmction decoders designed to decode instmctions of first and second 
instruction sets, respectively, and circuitry of a single instrucUon pipeUne designed to execute 
4 the instmctions decoded by either of the two instruction decoders; 

circuitry and/or software designed ,o detect when execution flows or transfers control 
from code coded in one instruction s^t to code coded in the other, piogram code in the first 
and second instruction sets using first and second different data stoi^ge conventions, 
8 respectively; and 

circuitry and/or software desired to respond to the detection by altering the data 
storage content of the computer to create a program context under the second data storage 
convention that is logically equivalent to a pre-altei^tion program context under the first data 
12 storage convention. 

97. (previously presented) The computer processor of claim 96. wherein the memory 
unit and software are designed to eff^t a transition between instruction boundaries, between 
execution in a region coded in the first instruction set using the first data storage convention 
to execution in a region coded in the second instrucUon set using the second data storage 
convention, so that code at the source of the flow or transfer may effect the execution 
transition without being specially coded for code at the destination. 

98. (previously presented) Themicioprocessorchipof claim 96. wherein the two 
data storage conventions are first and second calling conventions. 

99. (previously presented) Thecomputerprocessorof claim 98. wherein: 

one of the two calling conventions is a register-based calling convention, and the 
odier calling convention is a memory stack-based calhng convention. 
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100. (previously presented) the microprocessor chip of claim 98, further 
comprising: 

software and/or hardware designed to copy a datum from a firet location to a second 
location, the fim locaUon having a use under the first calling conventions analogous to the 
use of the second location under the second calling conventions. 

101. (previously presented) The microprocessor chip of claim 100. further 
comprising: 

software and/or hardware designed to copy a datum from a third location to a fourth, 
the third location having a use unW the first data storage convention analogous to the use of 
the third location under the first data storage convention and to the fourth location under the 
second data storage convention, the softwaie and/or hardware for the copying being 
progr^ed to assume that exacUy one of the first and third locations is no longer required 
by the execution of the program. 



1 
2 

3 



102. (previously presented) .The computer processor of claim 98. wherein 

a rule for altering the data storage content from the first calling convention to the 
second calling convention is determined based on an instruction at the location of execution 
at the source of the recognized execution flow or transfer. 

103. (previously presented) The computer processor of claim 98, wherein 

a rule for altering the data storage content fit,m the first calling convention to the 
second calling convention is determined by examining a descriptor associated with the 
instruction before the recognized execution flow or transfer. 

104. (cuirenUy amended) A method, comprising the steps of: 

executing instructions fetched from first, second and dtird regions of a single address 
space of the memory of a computer, the instmctions of the fn^t and^eeend region [fs)J being 
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4 coded for execution by computers of a first and oeoond architecture [[s]] md r th e i nstructionG 

5 of tho Gooond and third rogiono following a first and flocond data storage convention [[s]], the 

6 instructions of the second region being coded for execution by computers of a second 

7 architecture and following the first data storage convention , the instructions of the third 

8 region bein^ coded for execution bv computers of the second architecture and following a 

9 second data storage convention , resp e ctiv e ly , the memory regions having associated 

10 modifiable indicator elements, a hardware structure for storing the indicator elements 

1 1 enforcing a requirement that the memory regions be necessarily disjoint, the modifiable 

12 indicator elements each having a value indicating the architecture and data storage 

13 convention under which instructions from the associated region arc to be executed; 

14 when execution of the instruction data flows or transfers between the first, second and 

15 third regions, adapting the computer for execution in the architecture and/or convention of 

16 the region transferred to. 

105. (previously presented) The method of claim 104, wherein: 
the regions are pages managed by a virtual memory manager. 

106. (previously presented) The method of claim 105, wherein the modifiable 
indicator elements are stored in a table, each modifiable indicator element associated with a 
corresponding physical page frame. 

107. (previously presented) The method of claim 105, wherein the entries are entries 
of a translation look-aside buffer. 

108. (previously presented) The method of claim 104: 
wherein the two euchitectures arc two instruction set architectures; 
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and wherein the adapting step includes controlling instruction execution hardware of 
the computer to interpret the instructions according to the two instruction set architectures 
according to the modifiable indicator elements. 

109. (previously presented) The method of claim 108, wherein: 

one of the regions stores an off-the-shelf operating system binary coded in an 
instruction set non-native to the computer, the non-native instruction set providing access to a 
reduced subset of the resources of the computer. 

1 10. (previously presented) The method of claim 108, wherein the two conventions 
are first and second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
modifiable indicator element indicates the first data storage convention to a region whose 
modifiable indicator element indicates the second data storage convention, and in response to 
the recognition, altering the data storage content of the computer to create a program context 
under the second data storage convention that is logically equivalent to a pre-aiteration 
program context under the first data storage convention. 

111. (previously presented) The method of claim 104, wherein the two conventions 
are first and second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
indicator element indicates the first data storage convention to a region whose indictor 
element indicates the second data storage convention, and in response to the recognition, 
altering the data storage content of the computer to create a program context under the 
second data storage convention that is logically equivalent to a pre-alteration program 
context under the first data storage convention. 
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112. (pieviously presented) The method of claim 111, wherein: 
one of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stack-based calling convention. 



1 113. (previously presented) A computer processor, comprising: 

2 a processor pipeline configured to alternately execute instructions of computers of 

3 two different architectures; and 

4 a memory unit designed to fetch instructions from a computer memory for execution 

5 by the pipeline, and to fetch stored indicator elements associated with respective necessarily- 

6 disjoint memory regions of a single address space from which the instructions are to be 

7 fetched, each indicator element designed to store an indication of the architecture under 

8 which the instruction data of the associated region are to be executed by the processor 

9 pipeline, and to store a separate indicator element designed to indicate a data storage 

10 convention observed by instructions of the associated region; 

11 the memory unit and/or processor pipeline further designed to recognize an execution 

12 flow or transfer from a region whose indicator element indicates one instruction set 

13 architecture to another, and 

14 hardware and/or software designed to recognize when program execution has flowed 

15 or transferred from a region whose indicator element indicates the first data storage 

16 convention to a region whose indicator element indicates the second data storage convention, 

17 and in response to the recognition, to alter the data storage content of the computer to create a 

18 program context under the second data storage convention that is logically equivalent to a 

19 pre-alteration program context under the first data storage convention. 



1 14. (previously presented) The computer processor of claim 1 13, wherein the two 
architectures are two instruction set architectures, and further comprising: 
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processor pipeline control circuitry designed to control the processor pipeline to effect 
interpretation of the instructions under the two instruction set architectures alternately, according 
to the associated indicator elements. 

115. (previously presented) The computer processor of claim 114, further comprising: 
software programmed to manage a transition between the execution of a program 

executing in the first instruction set architecture, being an instruction set architecture native to 
the computer processor, and execution of an off-the-shelf operating system coded in the second 
instruction set, being an instruction set non-native to the computer, providing access to a reduced 
subset of the resources of the computer. 

1 16. (previously presented) The computer processor of claim 1 14: 

the data storage convention indicator elements being designed to stoi« an indication of a 
calling convention under which the instruction data of the associated region are coded for 
execution by the processor pipeline; 

and further comprising software programmed to alter the data storage content of a 
computer using the computer processor to create a program context under the second calling 
convention that is logically equivalent to a pre-alteration program context under the first calling 
convention; 

the memory unit further designed to recognize when program execution has flowed or 
transferred from a region whose indicator element indicates the first calling convention to a 
region whose indicator element indicates the second calling convention, and in response to the 
recognition » to invoke the transition management software. 

1 17. (cancelled) 

118. (cancelled) 
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1 19. (previously presented) The computer processor of claim 120, wherein the memory 
unit and software are designed to effect a transition between instmction boundaries, between 
execution in a region coded in the first instruction set using the first calling convention to 
execution in a region coded in the second instruction set using the second calhng convention, so 
that code at the source of the flow or transfer may effect the execution transition without being 
specially coded for code at the destination. 

120. (previously presented) The computer processor of claim 1 16, wherein the two data 
storage conventions are two calling conventions. 

121. (previously presented) The computer processor of claim 120, whei^in: 

one of the two calUng conventiops is a register-based calling convention, and the other 
calling convention is a memory stack-based calling convention. 

122. (previously presented) The computer processor of claim 120. wherein the logical 
resources for support of the first and secpnd instmction set architectuies are overlaid on the 
physical resources of the computer proc^sor according to a mapping that assigns corresponding 
resources of the two architectures to a cqnunon physical resource when the lesources serve 
analogous functions in the calling conventions of the two architectures. 

123. (previously presented) The computer processor of claim 120, further comprising: 
a transition manager designed to effect a transition between execution under the first 

calling convention to execution under the second calling convention, the transition manager 
designed to alter a bit representation of a datum from a fu^t representation to a second 
representation, the alteration of representation being chosen to preserve the meaning of the 
datum across the change in calling convention. 
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124. (p^viously presented) The computer prxKessor of claim 120, further comprising- 
software and/or hardware designed to copy a datum from a first location to a second 

location, the first location having a use under the fust calUng convention analogous to the use of 
the second location under the second calling convention. 

125. (previously presented) Tl^e co^puterprocessorof claim 124. further comprising: 
software and/or hardware designed to copy a datum from a thinl location to a fourth the 

third location having a use under the first calling convention analogous to the use of the thim 
location under the first calling convention and to the fourth location under the second calling 
convention, the software and/or hardware for the copying being progt^ed to assume that 
exactly one of the first and third locations is no longer required by the execution of the program. 

126. (previously presented) Thecomputerprocessor of claim 120, wherein 

a rule for altering the data storage content from the first calling convention to the second 
.s determined by examining a descriptor associated with the instruction before the recognized 

execution flow or transfer. 



127. (previously presented) The computer processor of claim 120. wherein control-flow 
mstnichons of the instruction set are classified into a plur^ty of classes; and 

the processor pipeline updates a record of the class of the classified control-flow 
instruction most recently executed ; 

the storage alteration process being determined, at least in part, by the instniction class 

record. 



128. (previously presented) The computer processor of claim 113, wherein: 
the regions arc pages managed by a virtual memoiy manager. 

129. (previously presented) The computer processor of claim 113. wherein the indicator 
elements are. stored in virtual address translation table entries. 



Second Response lo Office Action , , ^ 

This paper dated April 14.2005 114596-03-4000 S/N 09/385,394 

■ RCVD AT 4/14/2005 3:44:53 PM [Eastern Daytight Tbne] ' 8VR:USPTO-EFXRF-1/1 ' DNI8:8729306 ' CSIO:1212728S111 * DURATION (min-ss):27-«0 



FROM WILLKIE FARR 37 FAX DEPT- 



(THU) 4. t4'05 15;11/ST. 1 4 : 56/NO. 4200000484 P 



Application Serial No. 09/385,394 
Attorney Docket No. 1 14596-03-4000 

Amendn^m Dated ApriJ '4. 2005 -Response to Office Action Of October 25, 2004 



130. (p.vious.yp«) Theco^puterprocessorof Claim 113. wherein the indicator 
eIe„sto^ina.b.eofindicato^ 

table used by the vinua.™en,or,n,anager.the indicator ele^entsofthetabl^^ 
corresponding pages of the memory. 

131. ft«vi<,„.ly p^.„„d) Theoomputcrp^cc^^or Claim „3. whcei, feeMcator 
frame number. ^ 

132. (previously presented) ITie computer processor of claim 113 wherein- 

the indicator elements are sto^d in storage that is architecturally addressable when the 

processorpipeHne is executingmone of the computer architectures or processingcon 

and architecturally unaddressable when the processor pipehne executing in the other ' 

architecture or convention. 

desired . ^„ exccpuon „^ „^ ^ ^ 

m. The „emod Of clain, 87. wto,l. .he ta. and second exccuUon modes ^ 

hrst and second instruction set architectures. 

■n'e-th"dofda,n,87.whe^„U«E„,„<,,„„„,,,„„,„„^^^^ 
hrst and second calling conventions. 
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